# Cache Simulation

In this assignment, you will be using the ChampSim simulator to determine the best configuration of cache by modifying the mentioned parameters. The trace you will be using is allotted to you. **DO NOT** modify the source code of the ChampSim or other configuration parameters unless specified while doing the assignment. You are, however, encouraged to look into the source code and understand how a CPU is modeled using C++.

For all the questions, take the number of warmup instructions to be 20 million and number of simulation instructions to be 100 million. For each question begin by specifying the relevant cache parameters and then the parameter which is modified for each plot.

### Cache size, Cache Replacement Policies

- 1) Fix all levels of Cache to be Direct Mapped and the **size to be the same as default size**. Plot the Miss Rate (Cache Miss Rate) and IPC for at least 2 different Cache Replacement Policies by varying the cache size for **L1d** (at least 4 reasonable sizes). Bonus points for using more advanced Cache Replacement Policies (like MockingJay).
- 2) Fix all levels of Cache to be Direct Mapped and the **size to be the same as default size**. Plot the Miss Rate and IPC for at least 2 different Cache Replacement Policies by varying the cache size for **L2** (at least 4 reasonable sizes).

  Bonus points for using more advanced Cache Replacement Policies (like MockingJay).
- 3) Fix all levels of Cache to be Direct Mapped and the **size to be the same as default size**. Plot the Miss Rate and IPC for at least 2 different Cache Replacement Policies by varying the cache size for **L3** (at least 4 reasonable sizes).

  Bonus points for using more advanced Cache Replacement Policies (like MockingJay).
- 4) Fix all levels of Cache to be Fully Associative and the **size to be the same as default size**. Plot the Miss Rate and IPC for at least 2 different Cache Replacement Policies by varying the cache size for **L1d** (at least 4 reasonable sizes).

  Bonus points for using more advanced Cache Replacement Policies (like MockingJay).
- 5) Fix all levels of Cache to be Fully Associative and the **size to be the same as default size**. Plot the Miss Rate and IPC for at least 2 different Cache Replacement Policies by varying the cache size for **L2** (at least 4 reasonable sizes).

  Bonus points for using more advanced Cache Replacement Policies (like MockingJay).
- 6) Fix all levels of Cache to be Fully Associative and the **size to be the same as default size**. Plot the Miss Rate and IPC for at least 2 different Cache Replacement Policies by

varying the cache size for **L3** (at least 4 reasonable sizes). *Bonus points for using more advanced Cache Replacement Policies (like MockingJay)*.

## Virtual Memory, Physical Memory, TLB

- 7) Plot the TLB Miss Rate by varying the Physical Page size keeping the Virtual Memory size constant (at least 4 different sizes of rows). Also vary the number of levels of tables (at least 2 values including default). Analyze the result.
- 8) Plot the TLB Miss Rate by varying the Physical Page size keeping the Virtual Memory size constant (at least 4 different sizes of columns). Also vary the number of levels of tables (at least 2 values including default). Analyze the result.
- 9) Plot the TLB Miss Rate by varying the Physical Page size keeping the Virtual Memory size constant (at least 4 different numbers of ranks). Also vary the number of levels of tables (at least 2 values including default). Analyze the result.
- 10) Plot the TLB Miss Rate by varying the Virtual Memory size keeping the Physical Page size constant (at least 4 different sizes of page table). Also vary the number of levels of tables (at least 2 values including default). Analyze the result.
- 11) Plot the TLB Miss Rate by varying the TLB size by varying the number of sets (8 combinations). Analyze the result.
- 12) Plot the TLB Miss Rate by varying the TLB size by varying the number of ways (8 combinations). Analyze the result.

#### Cache size, Cache latency

13) Assuming the latency is proportional to the size of the cache, identify the best cache sizes suitable for your trace. For finding the proportionality constant use the default size and latency for each level of cache. **NOTE** that the latency parameter needs to be changed to enable appropriate simulation.

#### Prefetcher

14) Plot the Miss Rate and IPC for different prefetch policies (at least 5 different ones). *Bonus points for using more advanced prefetch policies!* 

## Cache associativity

15) Analyze how Miss Rate changes with varying associativity at L2 and LLC (at least 4 different associativity for each).

16) Analyze how Miss Rate changes with varying associativity at L1i and L1d (at least 4 different associativity for each).

## Multi tasking

- 17) Plot the Miss Rate for any 2 replacement policies and 4-way associativity for L2 while varying the number of cores (1, 2, 4, 8).

  Bonus points for using more advanced Cache Replacement Policies (like MockingJay).
- 18) Plot the Miss Rate for any 2 replacement policies and 16-way associativity for L2 while varying the number of cores (1, 2, 4, 8).

  Bonus points for using more advanced Cache Replacement Policies (like MockingJay).
- 19) Plot the Miss Rate for any 2 replacement policies and 4-way associativity for L3 while varying the number of cores (1, 2, 4, 8).

  Bonus points for using more advanced Cache Replacement Policies (like MockingJay).
- 20) Plot the Miss Rate for any 2 replacement policies and 16-way associativity for L3 while varying the number of cores (1, 2, 4, 8).

  Bonus points for using more advanced Cache Replacement Policies (like MockingJay).
- 21) Plot the Miss Rate for single and 8-core and vary the associativity for different levels of cache. Use 1-way and 8-way for associativity.

  Bonus points for using more advanced Cache Replacement Policies (like MockingJay).